package com.wyr.leetcode.step1.array;

public class IslandPerimeter {
    /**
     * 463. 岛屿的周长
     *
     * 给定一个 row x col 的二维网格地图 grid ，其中：grid[i][j] = 1 表示陆地， grid[i][j] = 0 表示水域。
     *
     * 网格中的格子 水平和垂直 方向相连（对角线方向不相连）。整个网格被水完全包围，但其中恰好有一个岛屿（或者说，一个或多个表示陆地的格子相连组成的岛屿）。
     *
     * 岛屿中没有“湖”（“湖” 指水域在岛屿内部且不和岛屿周围的水相连）。格子是边长为 1 的正方形。网格为长方形，且宽度和高度均不超过 100 。计算这个岛屿的周长。
     *
     */
    public int islandPerimeter(int[][] grid) {
        int ans = 0;
        for(int i=0;i<grid.length;i++){
            for(int j=0;j<grid[0].length;j++){
                if(grid[i][j] == 1){
                    // 看四周
                    // 上，如果是边界或者是水，则加入
                    if(i == 0 || grid[i-1][j] == 0){
                        ans++;
                    }
                    // 下，下边如果是水或者边界，则加入
                    if(i == grid.length-1 || grid[i+1][j] == 0){
                        ans++;
                    }
                    // 左，左边如果是水或者边界，则加入
                    if(j == 0 || grid[i][j-1] == 0){
                        ans++;
                    }
                    // 右，右边如果是水或者边界，则加入
                    if(j == grid[0].length-1 || grid[i][j+1] == 0){
                        ans++;
                    }
                }
            }
        }
        return ans;
    }
}
